|    | L#  | Hits  | Search Text                                                                                                                                                                             | DBs                |
|----|-----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| 1  | L1  | 154   | <pre>(((instruction prefetch\$3 fetch\$3) near5 (queue buffer)) near50 branch) near99 (((instruction prefetch\$3 fetch\$3) near5 (queue buffer)) near20 (select\$3 multiplex\$3))</pre> | USPAT;<br>US-PGPUB |
| 2  | L5  | 14903 | ((instruction prefetch\$3 fetch\$3) near5 (queue buffer))                                                                                                                               | USPAT;<br>US-PGPUB |
| 3  | L7  | 1000  | 5 near30 (branch near20 (predict\$3 history information indicat\$3 target taken))                                                                                                       | USPAT;<br>US-PGPUB |
| 4  | F8  | 2889  | 5 near30 cache                                                                                                                                                                          | USPAT;<br>US-PGPUB |
| 5  | L13 | 11452 | ((instruction prefetch\$3 fetch\$3) near3 (queue buffer))                                                                                                                               | USPAT;<br>US-PGPUB |
| 6  | L14 | 983   | 5 near30 (branch near10 (predict\$3 history information indicat\$3 target taken))                                                                                                       | USPAT;<br>US-PGPUB |
| 7  | L15 | 874   | 13 near30 (branch near10 (predict\$3 history information indicat\$3 target taken))                                                                                                      | USPAT;<br>US-PGPUB |
| 8  | L16 | 2448  | 13 near20 cache                                                                                                                                                                         | USPAT;<br>US-PGPUB |
| 9  | L18 | 287   | 15 near99 16                                                                                                                                                                            | USPAT;<br>US-PGPUB |
| 10 | L20 | 125   | 18 and (branch.ab,ti.)                                                                                                                                                                  | USPAT;<br>US-PGPUB |
| 11 | L28 | 278   | 27 and 8                                                                                                                                                                                | USPAT;<br>US-PGPUB |
| 12 | L34 | 15,3  | 28 not 20                                                                                                                                                                               | USPAT;<br>US-PGPUB |
| 13 | L27 | 428   | 7 and branch.ti,ab.                                                                                                                                                                     | USPAT;<br>US-PGPUB |

|    | 1                            |   |                                                                                                                                     |               |
|----|------------------------------|---|-------------------------------------------------------------------------------------------------------------------------------------|---------------|
|    | Docum<br>ent<br>ID           | ט | Title                                                                                                                               | Current<br>OR |
| 1  | US<br>20030<br>22600<br>3 A1 |   | Information processor having delayed branch function                                                                                | 712/238       |
| .2 | US<br>20030<br>18253<br>9 A1 |   | Storing execution results of mispredicted paths in a superscalar computer processor                                                 | 712/225       |
| 3  | US<br>20030<br>13121<br>2 A1 |   | Absolute address bits kept in branch history table                                                                                  | 711/203       |
| 4  | US<br>20030<br>07006<br>2 A1 |   | System and method for reducing computing system latencies associated with branch instructions                                       | 712/234       |
| 5  | US<br>20030<br>02875<br>8 A1 |   | SINGLE ARRAY BANKED BRANCH TARGET BUFFER                                                                                            | 712/238       |
| 6  | US<br>20030<br>00526<br>3 A1 |   | Shared resource queue for simultaneous multithreaded processing                                                                     | 712/218       |
| 7  | US<br>20020<br>19446<br>1 A1 |   | Speculative branch target address cache                                                                                             | 712/238       |
| 8  | US<br>20020<br>10802<br>9 A1 |   | Program counter (PC) relative addressing mode with fast displacement                                                                | 712/234       |
| 9  | US<br>20020<br>09992<br>6 A1 |   | Method and system for prefetching instructions in a superscalar processor                                                           | 712/207       |
| 10 | US<br>20020<br>09556<br>6 A1 |   | METHOD FOR PROCESSING BRANCH OPERATIONS                                                                                             | 712/239       |
| 11 | US<br>20010<br>05413<br>7 A1 |   | CIRCUIT ARRANGEMENT AND METHOD WITH IMPROVED BRANCH<br>PREFETCHING FOR SHORT BRANCH INSTRUCTIONS                                    | 712/11        |
| 12 | US<br>20010<br>03744<br>4 A1 |   | INSTRUCTION BUFFERING MECHANISM                                                                                                     | 712/207       |
| 13 | US<br>20010<br>02751<br>5 A1 |   | Apparatus and method of controlling instruction fetch                                                                               | 712/207       |
| 14 | US<br>66788<br>20 B1         |   | Processor and method for separately predicting conditional branches dependent on lock acquisition                                   | 712/239       |
| 15 | US<br>66585<br>58 B1         | ם | Branch prediction circuit selector with instruction context related condition type determining                                      | 712/239       |
| 16 | US<br>66511<br>62 B1         |   | Recursively accessing a branch target address cache using a target address previously accessed from the branch target address cache | 712/238       |
| 17 | US<br>66474<br>67 B1         |   | Method and apparatus for high performance branching in pipelined microsystems                                                       | 711/140       |
| 18 | US<br>66222<br>36 B1         |   | Microprocessor instruction fetch unit for processing instruction groups having multiple branch instructions                         | 712/206       |
| 19 | US<br>66119<br>10 B2         |   | Method for processing branch operations                                                                                             | 712/237       |

|    | Docum<br>ent<br>ID   | σ   | Title                                                                                                                                                                                          | Current<br>OR |
|----|----------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 20 | US<br>66091<br>94 B1 |     | Apparatus for performing branch target address calculation based on branch type                                                                                                                | 712/238       |
| 21 | US<br>66041<br>91 B1 |     | Method and apparatus for accelerating instruction fetching for a processor                                                                                                                     | 712/207       |
| 22 | US<br>65981<br>53 B1 |     | Processor and method that accelerate evaluation of pairs of condition-setting and branch instructions                                                                                          | 712/234       |
| 23 | US<br>65231<br>10 B1 |     | Decoupled fetch-execute engine with static branch prediction support                                                                                                                           | 712/239       |
| 24 | US<br>64776<br>40 B1 |     | Apparatus and method for predicting multiple branches and performing out-of-order branch resolution                                                                                            | 712/238       |
| 25 | US<br>64776<br>39 B1 |     | Branch instruction mechanism for processor                                                                                                                                                     | 712/237       |
| 26 | US<br>64571<br>17 B1 |     | Processor configured to predecode relative control transfer instructions and replace displacements therein with a target address                                                               | 712/213       |
| 27 | US<br>64461<br>97 B1 |     | Two modes for executing branch instructions of different<br>lengths and use of branch control instruction and register<br>set loaded with target instructions                                  | 712/237       |
| 28 | US<br>64426<br>81 B1 | . 🗆 | Pipelined central processor managing the execution of instructions with proximate successive branches in a cache-based data processing system while performing block mode transfer predictions | 712/238       |
| 29 | US<br>64271<br>92 B1 |     | Method and apparatus for caching victimized branch predictions                                                                                                                                 | 711/133       |
| 30 | US<br>64250<br>75 B1 |     | Branch prediction device with two levels of branch prediction cache                                                                                                                            | 712/239       |
| 31 | US<br>64185<br>25 B1 |     | Method and apparatus for reducing latency in set-associative caches using set prediction                                                                                                       | 711/213       |
| 32 | US<br>63895<br>31 B1 |     | Indexing branch target instruction memory using target address generated by branch control instruction to reduce branch latency                                                                | 712/237       |
| 33 | US<br>63857<br>19 B1 |     | Method and apparatus for synchronizing parallel pipelines in a superscalar microprocessor                                                                                                      | 712/235       |
| 34 | US<br>63743<br>48 B1 |     | Prioritized pre-fetch/preload mechanism for loading and speculative preloading of candidate branch target instruction                                                                          | 712/237       |
| 35 | US<br>63569<br>97 B1 |     | Emulating branch instruction of different instruction set in a mixed instruction stream in a dual mode system                                                                                  | 712/237       |
| 36 | US<br>63246<br>43 B1 |     | Branch prediction and target instruction control for processor                                                                                                                                 | 712/237       |
| 37 | US<br>63213<br>80 B1 |     | Method and apparatus for modifying instruction operations in a processor                                                                                                                       | 717/168       |
| 38 | US<br>63112<br>61 B1 |     | Apparatus and method for improving superscalar processors                                                                                                                                      | 712/23        |
| 39 | US<br>63049<br>62 B1 |     | Method and apparatus for prefetching superblocks in a computer processing system                                                                                                               | 712/240       |
| 40 | US<br>62894<br>42 B1 |     | Circuit and method for tagging and invalidating speculatively executed instructions                                                                                                            | 712/239       |
| 41 | US<br>62826<br>63 B1 |     | Method and apparatus for performing power management by suppressing the speculative execution of instructions within a pipelined microprocessor                                                | 713/320       |

|    | Docum<br>ent<br>ID   | U | Title                                                                                                                                                    | Current<br>OR |
|----|----------------------|---|----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 42 | US<br>62667<br>52 B1 |   | Reverse TLB for providing branch target address in a<br>microprocessor having a physically-tagged cache                                                  | 711/200       |
| 43 | US<br>62533<br>16 B1 |   | Three state branch history using one bit in a branch prediction mechanism                                                                                | 712/239       |
| 44 | US<br>62508<br>21 B1 |   | Method and apparatus for processing branch instructions in an instruction buffer                                                                         | 712/238       |
| 45 | US<br>61758<br>97 B1 |   | Synchronization of branch cache searches and allocation/modification/deletion of branch cache                                                            | 711/119       |
| 46 | US<br>61700<br>54 B1 |   | Method and apparatus for predicting target addresses for return from subroutine instructions utilizing a return address cache                            | 712/242       |
| 47 | US<br>61675<br>06 A  |   | Replacing displacement in control transfer instruction with encoding indicative of target address, including offset and target cache line location       | 712/213       |
| 48 | US<br>61579<br>98 A  |   | Method for performing branch prediction and resolution of two or more branch instructions within two or more branch prediction buffers                   | 712/238       |
| 49 | US<br>61579<br>88 A  |   | Method and apparatus for high performance branching in pipelined microsystems                                                                            | 711/140       |
| 50 | US<br>61346<br>49 A  |   | Control transfer indication in predecode which identifies control transfer instruction and an alternate feature of an instruction                        | 712/204       |
| 51 | US<br>61192<br>22 A  |   | Combined branch prediction and cache prefetch in a microprocessor                                                                                        | 712/238       |
| 52 | US<br>61192<br>20 A  |   | Method of and apparatus for supplying multiple instruction strings whose addresses are discontinued by branch instructions                               | 712/235       |
| 53 | US<br>60790<br>05 A  |   | Microprocessor including virtual address branch prediction<br>and current page register to provide page portion of virtual<br>and physical fetch address | 711/213       |
| 54 | US<br>60790<br>03 A  |   | Reverse TLB for providing branch target address in a<br>microprocessor having a physically-tagged cache                                                  | 711/200       |
| 55 | US<br>60761<br>46 A  |   | Cache holding register for delayed update of a cache line into an instruction cache                                                                      | 711/125       |
| 56 | US<br>60676<br>16 A  |   | Branch prediction device with two levels of branch prediction cache                                                                                      | 712/239       |
| 57 | US<br>60617<br>86 A  |   | Processor configured to select a next fetch address by partially decoding a byte of a control transfer instruction                                       | 712/237       |
| 58 | US<br>60353<br>87 A  |   | System for packing variable length instructions into fixed length blocks with indications of instruction beginning, ending, and offset within block      | 712/210       |
| 59 | US<br>59960<br>71 A  |   | Detecting self-modifying code in a pipelined processor with branch processing by comparing latched store address to subsequent target address            | 712/238       |
|    | US<br>59833<br>21 A  |   | Cache holding register for receiving instruction packets and for providing the instruction packets to a predecode unit and instruction cache             | 711/125       |
|    | US<br>59648<br>68 A  |   | Method and apparatus for implementing a speculative return stack buffer                                                                                  | 712/234       |
| 62 | US<br>59481<br>00 A  |   | Branch prediction and fetch mechanism for variable length instruction, superscalar pipelined processor                                                   | 712/238       |
| 63 | US<br>59448<br>17 A  |   | Method and apparatus for implementing a set-associative<br>branch target buffer                                                                          | 712/240       |
| 64 | US<br>59207<br>13 A  |   | Instruction decoder including two-way emulation code branching                                                                                           | 712/236       |

|      | Docum<br>ent<br>ID  | U | Title                                                                                                                                                                                  | Current<br>OR |
|------|---------------------|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 65   | US<br>59180<br>46 A |   | Method and apparatus for a branch instruction pointer table                                                                                                                            | 712/239       |
| 66   | US<br>59180<br>44 A |   | Apparatus and method for instruction fetching using a multi-port instruction cache directory                                                                                           | 712/235       |
| 67   | US<br>59037<br>51 A |   | Method and apparatus for implementing a branch target buffer in CISC processor                                                                                                         | 712/238       |
| 68   | US<br>58899<br>86 A |   | Instruction fetch unit including instruction buffer and secondary or branch target buffer that transfers prefetched instructions to the instruction buffer                             | 712/237       |
| 69   | US<br>58676<br>98 A |   | Apparatus and method for accessing a branch target buffer                                                                                                                              | 712/238       |
| 70   | US<br>58676<br>83 A |   | Method of operating a high performance superscalar microprocessor including a common reorder buffer and common register file for both integer and floating point operations            | 712/218       |
| 71   | US<br>58676<br>82 A |   | High performance superscalar microprocessor including a circuit for converting CISC instructions to RISC operations                                                                    | 712/210       |
| 72   | US<br>58570<br>89 A |   | Floating point stack and exchange instruction                                                                                                                                          | 712/222       |
| 73   | US<br>58505<br>43 A |   | Microprocessor with speculative instruction pipelining storing a speculative register value within branch target buffer for use in speculatively executing instructions after a return | 712/238       |
| 74   | US<br>58420<br>08 A |   | Method and apparatus for implementing a branch target buffer cache with multiple BTB banks                                                                                             | 712/240       |
| 75   | US<br>58128<br>39 A |   | Dual prediction branch system having two step of branch recovery process which activated only when mispredicted branch is the oldest instruction in the out-of-order unit              | 712/239       |
| 76   | US<br>58058<br>78 A |   | Method and apparatus for generating branch predictions for multiple branch instructions indexed by a single instruction pointer                                                        | 712/239       |
| 77   | US<br>58058<br>53 A |   | Superscalar microprocessor including flag operand renaming and forwarding apparatus                                                                                                    | 712/218       |
| 78   | US<br>58026<br>02 A |   | Method and apparatus for performing reads of related data from a set-associative cache memory                                                                                          | 711/204       |
| 79   | US<br>57969<br>98 A |   | Apparatus and method for performing branch target address calculation and branch prediciton in parallel in an information handling system                                              | 712/239       |
| 80   | US<br>57747<br>10 A |   | Cache line branch prediction scheme that shares among sets of a set associative cache                                                                                                  | 712/238       |
| 81   | US<br>57746<br>85 A |   | Method and apparatus for biasing cache LRU for prefetched instructions/data based upon evaluation of speculative conditions                                                            | 712/205       |
| 82   | US<br>57519<br>81 A |   | High performance superscalar microprocessor including a<br>speculative instruction queue for byte-aligning CISC<br>instructions stored in a variable byte-length format                | 712/204       |
| 83 . | US<br>57489<br>76 A |   | Mechanism for maintaining data coherency in a branch history instruction cache                                                                                                         | 712/240       |
| 84   | US<br>57489<br>32 A |   | Cache memory system for dynamically altering single cache memory line as either branch target entry or prefetch instruction queue based upon instruction sequence                      | 715/526       |
| 85   | US<br>57404<br>17 A |   | Pipelined processor operating in different power mode based on branch prediction state of branch history bit encoded as taken weakly not taken and strongly not taken states           | 712/239       |
| 86   | US<br>57404<br>15 A |   | Instruction supplying apparatus with a branch target buffer having the contents so updated as to enhance branch prediction accuracy                                                    | 712/238       |

|     | Docum<br>ent<br>ID  | σ | Title                                                                                                                                                                                               | Current<br>OR |
|-----|---------------------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 87  | US<br>57377<br>50 A |   | Partitioned single array cache memory having first and second storage regions for storing non-branch and branch instructions                                                                        | 711/129       |
| 88  | US<br>57375<br>90 A |   | Branch prediction system using limited branch target buffer updates                                                                                                                                 | 712/238       |
| 89  | US<br>57348<br>81 A |   | Detecting short branches in a prefetch buffer using target location information in a branch target cache                                                                                            | 712/238       |
| 90  | US<br>57322<br>35 A |   | Method and system for minimizing the number of cycles required to execute semantic routines                                                                                                         | 712/209       |
| 91  | US<br>57154<br>40 A |   | Branch instruction executing device for tracing branch instruments based on instruction type                                                                                                        | 712/233       |
| 92  | US<br>57064<br>92 A |   | Method and apparatus for implementing a set-associative branch target buffer                                                                                                                        | 712/238       |
| 93  | US<br>57014<br>48 A |   | Detecting segment limit violations for branch target when the branch unit does not supply the linear address                                                                                        | 712/233       |
| 94  | US<br>56969<br>58 A |   | Method and apparatus for reducing delays following the execution of a branch instruction in an instruction pipeline                                                                                 | 712/235       |
| 95  | US<br>56969<br>55 A |   | Floating point stack and exchange instruction                                                                                                                                                       | 712/222       |
| 96  | US<br>56871<br>10 A |   | Array having an update circuit for updating a storage location with a value stored in another storage location                                                                                      | 365/154       |
| 97  | US<br>56641<br>36 A |   | High performance superscalar microprocessor including a<br>dual-pathway circuit for converting cisc instructions to risc<br>operations                                                              | 712/208       |
| 98  | US<br>56550<br>98 A |   | High performance superscalar micróprocessor including a<br>circuit for byte-aligning cisc instructions stored in a<br>variable byte-length fórmat                                                   | 712/210       |
| 99  | US<br>56550<br>97 A |   | High performance superscalar microprocessor including an instruction cache circuit for byte-aligning CISC instructions stored in a variable byte-length format                                      | 712/204       |
| 100 | US<br>56511<br>25 A |   | High performance superscalar microprocessor including a common reorder buffer and common register file for both integer and floating point operations                                               | 712/218       |
| 101 | US<br>56491<br>37 A |   | Method and apparatus for store-into-instruction-stream detection and maintaining branch prediction cache consistency                                                                                | 712/207       |
| 102 | US<br>56447<br>44 A |   | Superscaler instruction pipeline having boundary identification logic for variable length instructions                                                                                              | 712/207       |
| 103 | US<br>56425<br>00 A |   | Method and apparatus for controlling instruction in pipeline processor                                                                                                                              | 712/233       |
| 104 | US<br>56405<br>26 A |   | Superscaler instruction pipeline having boundary indentification logic for variable length instructions                                                                                             | 712/207       |
| 105 | US<br>56320<br>23 A |   | Superscalar microprocessor including flag operand renaming and forwarding apparatus                                                                                                                 | 712/218       |
| 106 | US<br>56257<br>89 A |   | Apparatus for source operand dependendency analyses register renaming and rapid pipeline recovery in a microprocessor that issues and executes multiple instructions out-of-order in a single cycle | 712/217       |
| 107 | US<br>56257<br>87 A |   | Superscalar instruction pipeline using alignment logic responsive to boundary identification logic for aligning and appending variable length instructions to instructions stored in cache          | 712/204       |
| 108 | US<br>56236<br>15 A |   | Circuit and method for reducing prefetch cycles on microprocessors                                                                                                                                  | 712/238       |

|     | Docum<br>ent<br>ID  | Ū | Title                                                                                                                                                              | Current<br>OR |
|-----|---------------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 109 | US<br>56236<br>14 A |   | Branch prediction cache with multiple entries for returns having multiple callers                                                                                  | 712/240       |
| 110 | US<br>56066<br>75 A |   | Data processor for invalidating prefetched instruction or branch history information                                                                               | 712/237       |
| 111 | US<br>55749<br>37 A |   | Method and apparatus for improving instruction tracing operations in a computer system                                                                             | 712/23        |
| 112 | US<br>55748<br>71 A | 0 | Method and apparatus for implementing a set-associative branch target buffer                                                                                       | 712/200       |
| 113 | US<br>55155<br>18 A |   | Two-level branch prediction cache                                                                                                                                  | 712/239       |
| 114 | US<br>55111<br>75 A |   | Method an apparatus for store-into-instruction-stream detection and maintaining branch prediction cache consistency                                                | 712/216       |
| 115 | US<br>55091<br>30 A |   | Method and apparatus for grouping multiple instructions, issuing grouped instructions simultaneously, and executing grouped instructions in a pipelined processor  | 712/215       |
| 116 | US<br>54540<br>87 A |   | Branching system for return from subroutine using target address in return buffer accessed based on branch type information in BHT                                 | 712/240       |
| 117 | US<br>54148<br>22 A |   | Method and apparatus for branch prediction using branch prediction table with improved branch prediction effectiveness                                             | 712/240       |
| 118 | US<br>52874<br>67 A |   | Pipeline for removing and concurrently executing two or more branch instructions in synchronization with other instructions executing in the execution unit        | 712/235       |
| 119 | US<br>52300<br>68 A |   | Cache memory system for dynamically altering single cache memory line as either branch target entry or pre-fetch instruction queue based upon instruction sequence | 711/137       |
| 120 | US<br>52261<br>30 A |   | Method and apparatus for store-into-instruction-stream detection and maintaining branch prediction cache consistency                                               | 712/238       |
| 121 | US<br>51366<br>96 A |   | High-performance pipelined central processor for predicting the occurrence of executing single-cycle instructions and multicycle instructions                      | 712/240       |
| 122 | US<br>50500<br>68 A |   | Method and apparatus for using extracted program flow information to prepare for execution multiple instruction streams                                            | 712/206       |
| 123 | US<br>49439<br>08 A |   | Multiple branch analyzer for prefetching cache lines                                                                                                               | 712/240       |
| 124 | US<br>49263<br>23 A |   | Streamlined instruction processor                                                                                                                                  | 712/238       |
| 125 | US<br>48477<br>53 A |   | Pipelined computer                                                                                                                                                 | 712/238       |

|    | Docum<br>ent<br>ID            | υ | Title                                                                                                                                              | Current<br>OR |
|----|-------------------------------|---|----------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 1  | US<br>20040<br>01568<br>3 Al  |   | Two dimensional branch history table prefetching mechanism                                                                                         | 712/240       |
| 2  | US<br>20040<br>00321<br>6 A1  |   | Branch prediction apparatus and method                                                                                                             | 712/237       |
| 3  | US<br>20030<br>13572<br>2. A1 |   | Speculative load instructions with retry                                                                                                           | 712/235       |
| 4  | US<br>20030<br>09754<br>9 A1  |   | Predicted return address selection upon matching target in branch history table with entries in return address stack                               | 712/240       |
| 5  | US<br>20030<br>03350<br>5 A1  |   | Apparatus for processing instructions in a computing system                                                                                        | 712/215       |
| 6  | US<br>20030<br>01868<br>5 A1  |   | Method and system to perform a thread switching operation within a multithreaded processor based on detection of a branch instruction              | 718/102       |
| 7  | US<br>20020<br>19909<br>2 A1  |   | Split history tables for branch prediction                                                                                                         | 712/240       |
| 8  | US<br>20020<br>19446<br>4 A1  |   | Speculative branch target address cache with selective override by seconday predictor based on branch instruction type                             | 712/239       |
| 9  | US<br>20020<br>19446<br>3 A1  |   | Speculative hybrid branch direction predictor                                                                                                      | 712/239       |
| 10 | US<br>20020<br>19446<br>2 A1  |   | Apparatus and method for selecting one of multiple target addresses stored in a speculative branch target address cache per instruction cache line | 712/238       |
| 11 | US<br>20020<br>19446<br>0 A1  |   | Apparatus, system and method for detecting and correcting erroneous speculative branch target address cache branches                               | 712/238       |
| 12 | US<br>20020<br>18883<br>4 A1  |   | Apparatus and method for target address replacement in speculative branch target address cache                                                     | 712/238       |
| 13 | US<br>20020<br>18883<br>3 A1  |   | Dual call/return stack branch prediction system                                                                                                    | 712/236       |
| 14 | US<br>20020<br>16198<br>7 A1  |   | System and method including distributed instruction buffers holding a second instruction form                                                      | 712/205       |
| 15 | US<br>20020<br>09191<br>3 A1  |   | Re-order buffer managing method and processor                                                                                                      | 712/218       |
| 16 | US<br>20020<br>08331<br>0 A1  |   | METHOD AND APPARATUS FOR PREDICTING LOOP EXIT BRANCHES                                                                                             | 712/233       |
| 17 | US<br>20010<br>03744<br>7 A1  |   | Simultaneous and redundantly threaded processor branch outcome queue                                                                               | 712/239       |

|    | Docum<br>ent<br>ID           | Ū | Title                                                                                                                              | Current<br>OR |
|----|------------------------------|---|------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 18 | US<br>20010<br>03230<br>9 A1 |   | Static branch prediction mechanism for conditional branch instructions                                                             | 712/239       |
| 19 | US<br>66979<br>37 B1         |   | Split history tables for branch prediction                                                                                         | 712/240       |
| 20 | US<br>65981<br>54 B1         |   | Precoding branch instructions to reduce branch-penalty in pipelined processors                                                     | 712/237       |
| 21 | US<br>65981<br>52 B1         |   | Increasing the overall prediction accuracy for multi-cycle branch prediction and apparatus by enabling quick recovery              | 712/228       |
| 22 | US<br>65713<br>31 B2         |   | Static branch prediction mechanism for conditional branch instructions                                                             | 712/239       |
| 23 | US<br>65464<br>81 B1         |   | Split history tables for branch prediction                                                                                         | 712/240       |
| 24 | US<br>65300<br>16 B1         |   | Predicted return address selection upon matching target in branch history table with entries in return address stack               | 712/237       |
| 25 | US<br>65265<br>02 B1         |   | Apparatus and method for speculatively updating global branch history with branch prediction prior to resolution of branch outcome | 712/239       |
| 26 | US<br>64991<br>01 B1         |   | Static branch prediction mechanism for conditional branch instructions                                                             | 712/239       |
| 27 | US<br>64876<br>37 B1         |   | Method and system for clearing dependent speculations from a request queue                                                         | 711/133       |
| 28 | US<br>64386<br>82 B1         |   | Method and apparatus for predicting loop exit branches                                                                             | 712/241       |
| 29 | US<br>64386<br>56 B1         |   | Method and system for cancelling speculative cache prefetch requests                                                               | 711/137       |
| 30 | US<br>64217<br>74 B1         |   | Static branch predictor using opcode of instruction preceding conditional branch                                                   | 712/239       |
| 31 | US<br>64185<br>16 B1         |   | Method and system for managing speculative requests in a multi-level memory hierarchy                                              | 711/138       |
| 32 | US<br>63816<br>91 B1         |   | Method and apparatus for reordering memory operations along multiple execution paths in a processor                                | 712/236       |
| 33 | US<br>63670<br>01 B1         |   | Processor including efficient fetch mechanism for LO and L1 caches                                                                 | 712/205       |
| 34 | US<br>63473<br>69 B1         |   | Method and circuit for single cycle multiple branch history table access                                                           | 712/240       |
| 35 | US<br>63381<br>36 B1         |   | Pairing of load-ALU-store with conditional branch                                                                                  | 712/221       |
| 36 | US<br>62726<br>24 B1         |   | Method and apparatus for predicting multiple conditional branches                                                                  | 712/239       |
| 37 | US<br>62694<br>36 B1         |   | Superscalar microprocessor configured to predict return addresses from a return stack storage                                      | 712/23        |
| 38 | US<br>62634<br>27 B1         |   | Branch prediction mechanism                                                                                                        | 712/236       |
| 39 | US<br>62601<br>38 B1         |   | Method and apparatus for branch instruction processing in a processor                                                              | 712/239       |

|    | Docum<br>ent<br>ID   | σ | Title                                                                                                                                                                     | Current<br>OR |
|----|----------------------|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 40 | US<br>62567<br>28 B1 |   | Processor configured to selectively cancel instructions from its pipeline responsive to a predicted-taken short forward branch instruction                                | 712/236       |
| 41 | US<br>62471<br>24 B1 |   | Branch prediction entry with target line index calculated using relative position of second operation of two step branch operation in a line of instructions              | 712/240       |
| 42 | US<br>62471<br>22 B1 |   | Method and apparatus for performing branch prediction combining static and dynamic branch predictors                                                                      | 712/239       |
| 43 | US<br>62470<br>97 B1 |   | Aligned instruction cache handling of instruction fetches across multiple predicted branch instructions                                                                   | 711/125       |
| 44 | US<br>62336<br>76 B1 |   | Apparatus and method for fast forward branch                                                                                                                              | 712/233       |
| 45 | US<br>62197<br>84 B1 |   | Processor with N adders for parallel target addresses calculation                                                                                                         | 712/235       |
| 46 | US<br>61991<br>54 B1 |   | Selecting cache to fetch in multi-level cache system based on fetch address source and pre-fetching additional data to the cache for future access                        | 712/205       |
| 47 | US<br>61890<br>91 B1 |   | Apparatus and method for speculatively updating global history and restoring same on branch misprediction detection                                                       | 712/240       |
| 48 | US<br>61675<br>10 A  |   | Instruction cache configured to provide instructions to a microprocessor having a clock cycle time less than a cache access time of said instruction cache                | 712/239       |
| 49 | US<br>61122<br>93 A  |   | Processor configured to generate lookahead results from operand collapse unit and for inhibiting receipt/execution of the first instruction based on the lookahead result | 712/216       |
| 50 | US<br>61087<br>75 A  |   | Dynamically loadable pattern history tables in a multi-task microprocessor                                                                                                | 712/240       |
| 51 | US<br>61015<br>90 A  |   | Virtual memory system with local and global virtual address translation                                                                                                   | 711/203       |
| 52 | US<br>61015<br>77 A  |   | Pipelined instruction cache and branch prediction mechanism therefor                                                                                                      | 711/125       |
| 53 | US<br>60981<br>67 A  |   | Apparatus and method for fast unified interrupt recovery and branch recovery in processors supporting out-of-order execution                                              | 712/218       |
| 54 | US<br>60887<br>93 A  |   | Method and apparatus for branch execution on a multiple-instruction-set-architecture microprocessor                                                                       | 712/239       |
| 55 | US<br>60651<br>15 A  |   | Processor and method for speculatively executing instructions from multiple instruction streams indicated by a branch instruction                                         | 712/235       |
| 56 | US<br>60444<br>59 A  |   | Branch prediction apparatus having branch target buffer for effectively processing branch instruction                                                                     | 712/237       |
| 57 | US<br>60292<br>28 A  |   | Data prefetching of a load target buffer for post-branch instructions based on past prediction accuracy's of branch predictions                                           | 711/137       |
| 58 | US<br>60165<br>45 A  |   | Reduced size storage apparatus for storing cache-line-related<br>data in a high frequency microprocessor                                                                  | 712/238       |
| 59 | US<br>60147<br>34 A  |   | Superscalar microprocessor configured to predict return addresses from a return stack storage                                                                             | 712/23        |
| 60 | US<br>60031<br>28 A  |   | Number of pipeline stages and loop length related counter differential based end-loop prediction                                                                          | 712/241       |
| 61 | US<br>59833<br>35 A  |   | Computer system having organization for multiple condition code setting and for testing instruction out-of-order                                                          | 712/23        |
| 62 | US<br>59789<br>07 A  |   | Delayed update register for an array                                                                                                                                      | 712/239       |

|    | Docum<br>ent<br>ID  | σ | Title                                                                                                                                                 | Current<br>OR |
|----|---------------------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 63 | US<br>59564<br>95 A |   | Method and system for processing branch instructions during emulation in a data processing system                                                     | 703/26        |
| 64 | US<br>59548<br>15 A |   | Invalidating instructions in fetched instruction blocks upon predicted two-step branch operations with second operation relative target address       | 712/237       |
| 65 | US<br>59516<br>79 A |   | Microprocessor circuits, systems, and methods for issuing successive iterations of a short backward branch loop in a single cycle                     | 712/241       |
| 66 | US<br>59434<br>94 A |   | Method and system for processing multiple branch instructions that write to count and link registers                                                  | 712/238       |
| 67 | US<br>59352<br>41 A |   | Multiple global pattern history tables for branch prediction in a microprocessor                                                                      | 712/240       |
| 68 | US<br>59319<br>44 A |   | Branch instruction handling in a self-timed marking system                                                                                            | 712/239       |
| 69 | US<br>59283<br>58 A |   | Information processing apparatus which accurately predicts whether a branch is taken for a conditional branch instruction, using small-scale hardware | 712/239       |
| 70 | US<br>59180<br>45 A |   | Data processor and data processing system                                                                                                             | 712/237       |
| 71 | US<br>58988<br>66 A |   | Method and apparatus for counting remaining loop instructions and pipelining the next instruction                                                     | 712/241       |
| 72 | US<br>58929<br>36 A |   | Speculative register file for storing speculative register states and removing dependencies between instructions utilizing the register               | 712/216       |
| 73 | US<br>58813<br>08 A |   | Computer organization for multiple and out-of-order execution of condition code testing and setting instructions out-of-order                         | 712/23        |
| 74 | US<br>58812<br>78 A |   | Return address prediction system which adjusts the contents of return stack storage to enable continued prediction after a mispredicted branch        | 712/242       |
| 75 | US<br>58782<br>55 A |   | Update unit for providing a delayed update to a branch prediction array                                                                               | 712/240       |
| 76 | US<br>58753<br>24 A |   | Superscalar microprocessor which delays update of branch prediction information in response to branch misprediction until a subsequent idle clock     | 712/238       |
| 77 | US<br>58705<br>75 A |   | Indirect unconditional branches in data processing system emulation mode                                                                              | 712/209       |
| 78 | US<br>58647<br>07 A |   | Superscalar microprocessor configured to predict return addresses from a return stack storage                                                         | 712/23        |
| 79 | US<br>58646<br>97 A |   | Microprocessor using combined actual and speculative branch history prediction                                                                        | 712/240       |
| 80 | US<br>58600<br>17 A |   | Processor and method for speculatively executing instructions from multiple instruction streams indicated by a branch instruction                     | 712/23        |
| 81 | US<br>58505<br>42 A |   | Microprocessor instruction hedge-fetching in a multiprediction branch environment                                                                     | 712/235       |
| 82 | US<br>58482<br>69 A |   | Branch predicting mechanism for enhancing accuracy in branch prediction by reference to data                                                          | 712/239       |
| 83 | US<br>58482<br>68 A |   | Data processor with branch target address generating unit                                                                                             | 712/233       |
| 84 | US<br>58389<br>44 A | 0 | System for storing processor register data after a<br>mispredicted branch                                                                             | 712/218       |
| 85 | US<br>58359<br>67 A |   | Adjusting prefetch size based on source of prefetch address                                                                                           | 711/213       |

|     | Docum<br>ent<br>ID  | σ | Title                                                                                                                                                                        | Current<br>OR |
|-----|---------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 86  | US<br>58359<br>51 A |   | Branch processing unit with target cache read prioritization protocol for handling multiple hits                                                                             | 711/145       |
| 87  | US<br>58322<br>59 A |   | Apparatus for superscalar instruction pre-decoding using cached instruction lengths                                                                                          | 712/238       |
| 88  | US<br>58260<br>70 A |   | Apparatus and method for maintaining status flags and condition codes using a renaming technique in an out of order floating point execution unit                            | 712/222       |
| 89  | US<br>58225<br>76 A |   | Branch history table with branch pattern field                                                                                                                               | 712/239       |
| 90  | US<br>58225<br>74 A |   | Functional unit with a pointer for mispredicted resolution, and a superscalar microprocessor employing the same                                                              | 712/233       |
| 91  | US<br>58093<br>24 A |   | Multiple instruction dispatch system for pipelined microprocessor without branch breaks                                                                                      | 712/23        |
| 92  | US<br>57940<br>27 A |   | Method and apparatus for managing the execution of instructons with proximate successive branches in a cache-based data processing system                                    | 712/238       |
| 93  | US<br>57846<br>04 A |   | Method and system for reduced run-time delay during conditional branch execution in pipelined processor systems utilizing selectively delayed sequential instruction purging | 712/238       |
| 94  | US<br>57846<br>03 A |   | Fast handling of branch delay slots on mispredicted branches                                                                                                                 | 712/234       |
| 95  | US<br>57649<br>70 A |   | Method and apparatus for supporting speculative branch and link/branch on count instructions                                                                                 | 712/233       |
| 96  | US<br>57649<br>40 A |   | Processor and method for executing a branch instruction and an associated target instruction utilizing a single instruction fetch                                            | 712/206       |
| 97  | US<br>57614<br>90 A |   | Changing the meaning of a pre-decode bit in a cache memory depending on branch prediction mode                                                                               | 712/239       |
| 98  | US<br>57522<br>59 A |   | Instruction cache configured to provide instructions to a microprocessor having a clock cycle time less than a cache access time of said instruction cache                   | 711/125       |
| 99  | US<br>57520<br>14 A |   | Automatic selection of branch prediction methodology for subsequent branch instruction based on outcome of previous branch prediction                                        | 712/240       |
| 100 | US<br>57404<br>16 A |   | Branch processing unit with a far target cache accessed by indirection from the target cache                                                                                 | 712/238       |
| 101 | US<br>57375<br>62 A |   | CPU pipeline having queuing stage to facilitate branch instructions                                                                                                          | 712/218       |
| 102 | US<br>57322<br>53 A |   | Branch processing unit with target cache storing history for predicted taken branches and history cache storing history for predicted not-taken branches                     | 712/239       |
| 103 | US<br>57322<br>43 A |   | Branch processing unit with target cache using low/high banking to support split prefetching                                                                                 | 711/137       |
| 104 | US<br>57064<br>91 A |   | Branch processing unit with a return stack including repair using pointers from different pipe stages                                                                        | 712/234       |
| 105 | US<br>56921<br>67 A |   | Method for verifying the correct processing of pipelined instructions including branch instructions and self-modifying code in a microprocessor                              | 712/226       |
| 106 | US<br>56873<br>49 A |   | Data processor with branch target address cache and subroutine return address cache and method of operation                                                                  | 711/137       |
| 107 | US<br>56641<br>35 A |   | Apparatus and method for reducing delays due to branches                                                                                                                     | 712/201       |
| 108 | US<br>56491<br>45 A |   | Data processor processing a jump instruction                                                                                                                                 | 711/213       |

|     | Docum<br>ent<br>ID  | ซ | Title                                                                                                                      | Current<br>OR |
|-----|---------------------|---|----------------------------------------------------------------------------------------------------------------------------|---------------|
| 109 | US<br>56341<br>36 A |   | Data processor and method of controlling the same                                                                          | 712/237       |
| 110 | US<br>56341<br>03 A |   | Method and system for minimizing branch misprediction penalties within a processor                                         | 712/235       |
| 111 | US<br>56301<br>57 A |   | Computer organization for multiple and out-of-order execution of condition code testing and setting instructions           | 712/23        |
| 112 | US<br>56175<br>50 A |   | Data processor generating jump target address of a jump instruction in parallel with decoding of the instruction           | 712/207       |
| 113 | US<br>56066<br>82 A |   | Data processor with branch target address cache and subroutine return address cache and method of operation                | 711/204       |
| 114 | US<br>56066<br>76 A |   | Branch prediction and resolution apparatus for a superscalar computer processor                                            | 712/239       |
| 115 | US<br>55948<br>84 A |   | Cache memory system having a plurality of ports                                                                            | 711/125       |
| 116 | US<br>55926<br>79 A |   | Apparatus and method for distributed control in a processor architecture                                                   | 712/23        |
| 117 | US<br>55926<br>37 A |   | Data processor processing a jump instruction                                                                               | 712/237       |
| 118 | US<br>55902<br>96 A |   | Data processor processing a jump instruction                                                                               | 712/229       |
| 119 | US<br>55532<br>55 A |   | Data processor with programmable levels of speculative instruction fetching and method of operation                        | 712/235       |
| 120 | US<br>55532<br>54 A |   | Instruction cache access and prefetch process controlled by a predicted instruction-path mechanism                         | 712/207       |
| 121 | US<br>55133<br>30 A |   | Apparatus for superscalar instruction predecoding using cached instruction lengths                                         | 712/204       |
| 122 | US<br>54855<br>87 A |   | Data processor calculating branch target address of a branch instruction in parallel with decoding of the instruction      | 712/234       |
| 123 | US<br>54796<br>16 A |   | Exception handling for prefetched instruction bytes using valid bits to identify instructions that will cause an exception | 712/212       |
| 124 | US<br>54539<br>27 A |   | Data processor for processing branch instructions                                                                          | 712/235       |
| 125 | US<br>54427<br>66 A |   | Method and system for distributed instruction address translation in a multiscalar data processing system                  | 711/204       |
| 126 | US<br>54427<br>56 A |   | Branch prediction and resolution apparatus for a superscalar computer processor                                            | 712/238       |
| 127 | US<br>54349<br>85 A |   | Simultaneous prediction of multiple branches for superscalar processing                                                    | 712/240       |
| 128 | US<br>54210<br>20 A |   | Counter register implementation for speculative execution of branch on count instructions                                  | 712/237       |
| 129 | US<br>54106<br>57 A |   | Method and system for high speed floating point exception enabled operation in a multiscalar processor system              | 712/215       |
| 130 | US<br>54044<br>67 A |   | CPU having pipelined instruction unit and effective address calculation unit with retained virtual address capability      | 712/207       |
| 131 | US<br>53945<br>30 A |   | Arrangement for predicting a branch target address in the second iteration of a short loop                                 | 712/240       |

|     | Docum<br>ent<br>ID  | Ū | Title                                                                                                                                                                        | Current |
|-----|---------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 132 | US<br>53945<br>29 A |   | Branch prediction unit for high-performance processor                                                                                                                        | 712/240 |
| 133 | US<br>53815<br>33 A |   | Dynamic flow instruction cache memory organized around trace segments independent of virtual address line                                                                    | 712/215 |
| 134 | US<br>53677<br>03 A |   | Method and system for enhanced branch history prediction accuracy in a superscalar processor system                                                                          | 712/23  |
| 135 | US<br>53534<br>21 A | 0 | Multi-prediction branch prediction mechanism                                                                                                                                 | 712/240 |
| 136 | US<br>53534<br>19 A |   | Memory-side driven anticipatory instruction transfer interface with processor-side instruction selection                                                                     | 712/235 |
| 137 | US<br>53275<br>47 A |   | Two-level branch prediction cache                                                                                                                                            | 711/137 |
| 138 | US<br>53136<br>34 A |   | Computer system branch prediction of subroutine returns                                                                                                                      | 712/240 |
| 139 | US<br>52972<br>81 A |   | Multiple sequence processor system                                                                                                                                           | 712/216 |
| 140 | US<br>52838<br>73 A |   | Next line prediction apparatus for a pipelined computed system                                                                                                               | 712/207 |
| 141 | US<br>52768<br>82 A |   | Subroutine return through branch history table                                                                                                                               | 712/240 |
| 142 | US<br>52652<br>13 A |   | Pipeline system for executing predicted branch target instruction in a cycle concurrently with the execution of branch instruction                                           | 712/240 |
| 143 | US<br>52108<br>31 A |   | Methods and apparatus for insulating a branch prediction<br>mechanism from data dependent branch table updates that<br>result from variable test operand locations           | 712/240 |
| 144 | US<br>51971<br>36 A |   | Processing system for branch instruction                                                                                                                                     | 712/238 |
| 145 | US<br>51631<br>40 A |   | Two-level branch prediction cache                                                                                                                                            | 711/140 |
| 146 | US<br>51558<br>43 A |   | Error transition mode for multi-processor system                                                                                                                             | 714/5   |
| 147 | US<br>51426<br>34 A |   | Branch prediction                                                                                                                                                            | 712/240 |
| 148 | US<br>51270<br>91 A |   | System for reducing delay in instruction execution by executing branch instructions in separate processor while dispatching subsequent instructions to primary processor     | 712/238 |
| 149 | US<br>50348<br>80 A | ] | Apparatus and method for executing a conditional branch instruction                                                                                                          | 712/234 |
| 150 | US<br>49910<br>80 A |   | Pipeline processing apparatus for executing instructions in three streams, including branch stream pre-execution processor for pre-executing conditional branch instructions | 712/206 |
|     | US<br>49531<br>21 A | _ | Circuitry for and method of controlling an instruction buffer in a data-processing system                                                                                    | 712/241 |
| 152 | US<br>42009<br>27 A |   | Multi-instruction stream branch processing mechanism                                                                                                                         | 712/235 |
| .53 | US<br>39407<br>41 A |   | Information processing device for processing instructions including branch instructions                                                                                      | 712/238 |